

# PARALLEL STL IN 5 MINUTES

Mikhail Dvorskiy, Jim Cownie, Alexey Kukanov

### What is the Parallel STL?

- An extension of the C++ Standard Template Library algorithms with the "execution policy" argument
- Support for parallel execution policies is in the C++17 standard
- Support for the unseq policy is on track for the next C++ standard
- Support for vector policies is being developed in the Parallelism Technical Specification (TS) v2 which has just been approved for an ISO vote



Copyright © 2018, Intel Corporation. All rights reserved.
\*Other names and brands may be claimed as the property of others.

## Example of Use

• The version of "transform" is resolved by ExecutionPolicy type (see [algorithms.parallel.overloads]):

```
template <class ExecutionPolicy, class InputIt, class OutputIt, class UnaryOp>
OutputIt transform(ExecutionPolicy&& exec, ...);
```

• Beware: for vector policies, the lambda/functor/predicate should be vectorizable

## Parallel STL advantages

#### Compared with other parallelization tools and libraries

- Standard parallelization tool coming with C++ 17
- Simple high-level API
- Can express two different styles of parallelism (with more to come)
- Compile-time dispatch: no runtime overhead
- Facilitates correctness (no races if used as expected)
- Scalability & Composability
  - depends on implementation back-end



## Intel's Parallel STL implementation



#### How to Get Involved

- Parallel STL main repository (upstream) at GitHub: <a href="https://github.com/intel/parallelstl">https://github.com/intel/parallelstl</a>
  - You can contribute by sending patches or preparing pull requests
- Intel contributes the implementation to both GCC and LLVM
  - GCC community is adjusting the code for use in libstdc++ (WIP)
  - LLVM community can adjust the code for use in libc++
    - Integrate codebases, adjust/extend/add tests, etc.
  - Communities contribute integration changes upstream
- Contact us (via <u>inteltbbdevelopers@intel.com</u>) if you are interested but don't know where to start
- We want your help! (LLVM is behind GCC here ②)



## Legal Disclaimer & Optimization Notice

INFORMATION IN THIS DOCUMENT IS PROVIDED "AS IS". NO LICENSE, EXPRESS OR IMPLIED, BY ESTOPPEL OR OTHERWISE, TO ANY INTELLECTUAL PROPERTY RIGHTS IS GRANTED BY THIS DOCUMENT. INTEL ASSUMES NO LIABILITY WHATSOEVER AND INTEL DISCLAIMS ANY EXPRESS OR IMPLIED WARRANTY, RELATING TO THIS INFORMATION INCLUDING LIABILITY OR WARRANTIES RELATING TO FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR INFRINGEMENT OF ANY PATENT, COPYRIGHT OR OTHER INTELLECTUAL PROPERTY RIGHT.

Software and workloads used in performance tests may have been optimized for performance only on Intel microprocessors. Performance tests, such as SYSmark and MobileMark, are measured using specific computer systems, components, software, operations and functions. Any change to any of those factors may cause the results to vary. You should consult other information and performance tests to assist you in fully evaluating your contemplated purchases, including the performance of that product when combined with other products. For more complete information visit <a href="https://www.intel.com/benchmarks">www.intel.com/benchmarks</a>.

Copyright © 2018, Intel Corporation. All rights reserved. Intel, Pentium, Xeon, Xeon Phi, Core, VTune, Cilk, and the Intel logo are trademarks of Intel Corporation in the U.S. and other countries.

#### **Optimization Notice**

Intel's compilers may or may not optimize to the same degree for non-Intel microprocessors for optimizations that are not unique to Intel microprocessors. These optimizations include SSE2, SSE3, and SSSE3 instruction sets and other optimizations. Intel does not guarantee the availability, functionality, or effectiveness of any optimization on microprocessors not manufactured by Intel. Microprocessor-dependent optimizations in this product are intended for use with Intel microprocessors. Certain optimizations not specific to Intel microprocessors. Please refer to the applicable product User and Reference Guides for more information regarding the specific instruction sets covered by this notice.

Notice revision #20110804

